<template>
  <el-row class="module-menu">
    <el-col v-show="loading" class="module-menu-item" :span="24">
      <div v-loading="loading" style="width: 100%;height: 200px;"></div>
    </el-col>
    <el-col class="module-menu-item" :span="24" v-for="(module,index) in moduleList" :key="module.moduleId"
            @click.native="showSubMenuHandle(module)"
            @mouseenter.native="mouseEnterHandle(index)"
            @mouseleave.native="mouseLeaveHandle(index)"
    >
      <span>{{module.moduleName}}</span>
      <i v-if="module.childrenCount>0" class="el-icon-arrow-right"></i>
      <el-button v-else-if="isEdit" type="text" size="mini" v-show="addButtonVisibleList[index]" @click="addSubMenuHandle($event, module)"><i class="el-icon-plus"></i></el-button>
    </el-col>
    <el-col :span="24" v-if="isEdit">
      <div v-show="moduleList.length>0">
        <el-divider></el-divider>
      </div>
      <add-module-menu-item ref="addModuleMenu" v-model="moduleName" :project-id="projectId" :module-pid="modulePid" @added="addModuleHandle" />
    </el-col>
  </el-row>
</template>

<script>
import AddModuleMenuItem from "@/components/Module/SelectModule/add";
import {listModule} from "@/api/system/module";

export default {
  name: "ModuleMenu",
  components: { AddModuleMenuItem },
  data() {
    return {
      loading: false,
      moduleName: null,
      moduleList: [],
      params: {
        pageIndex: 1,
          pageSize: 9999,
          modulePid: 0,
          projectId: null
      },
      addButtonVisibleList: [],
    }
  },
  props: {
    projectId: {
      type: Number,
      default: null
    },
    modulePid: {
      type: Number,
      default: 0
    },
    isEdit: {
      type: Boolean,
      default: true
    }
  },
  created() {
    this.getModuleList();
  },
  methods: {
    getModuleList() {
      this.params.projectId=this.projectId;
      this.params.modulePid=this.modulePid;
      this.loading = true;
      listModule(this.params).then(res=>{
        this.loading = false;
        this.moduleList = res.data;
        let visibleList = [];
        res.data.forEach(m=>{
          visibleList.push(false);
        })
        this.addButtonVisibleList = visibleList;
        this.$refs.addModuleMenu.setFormVisible(this.moduleList.length==0);
      }).catch(e=>{
        this.loading = false;
      })
    },
    addModuleHandle(modules) {
      this.getModuleList();
      this.$forceUpdate();
    },
    open(projectId,modulePid) {
      if(projectId){
        this.params.projectId=projectId;
      }
      if(modulePid){
        this.params.modulePid=modulePid;
      }
      this.getModuleList();
    },
    showSubMenuHandle(module) {
      if(module.childrenCount>0) {
        this.$emit('clickDirectory', module);
      } else {
        this.$emit('clickMenu', module);
      }
    },
    addSubMenuHandle(event, module) {
      this.$emit('clickAddSubMenu', module);
      event.stopPropagation();
    },
    mouseEnterHandle(index) {
      this.addButtonVisibleList[index]=true;
      this.$forceUpdate();
    },
    mouseLeaveHandle(index) {
      this.addButtonVisibleList[index]=false;
      this.$forceUpdate();
    }
  }
}
</script>

<style lang="scss" scoped>
  .module-menu {
    width: 200px;
    .el-divider {
      margin: 5px 15px 15px 15px;
      width: calc(100% - 30px);
      background-color: #f1f1f1;
    }
  }
  .module-menu-item {
    padding: 5px 20px;
    min-height: 38px;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .module-menu-item:hover {
    background-color: #F2F6FC;
    border-radius: 5px;
    cursor: pointer;
  }
</style>
